SQLite 函数

SQLite COALESCE() 函数返回列表中的第一个非空表达式。如果所有表达式的计算结果为NULL,则此函数将返回NULL。

语法

COALESCE(expression1, expression2, ... expression_n) 

参数

expression1、expression2、...expression_n必填。 指定要测试非空值的表达式。

返回值

返回第一个非空表达式

示例 1:

下面的示例显示了 COALESCE() 函数的用法。

SELECT COALESCE(NULL, NULL, NULL, 'London', 'Paris');
Result: 'London'

SELECT COALESCE('Mumbai', NULL, NULL, 'London', 'Paris');
Result: 'Mumbai'

SELECT COALESCE(NULL, NULL, NULL, NULL, NULL);
Result: NULL

SELECT COALESCE(1, 2, NULL, NULL, 3);
Result: 1

SELECT COALESCE(NULL, 10, NULL, 20, 30);
Result: 10 

示例 2:

考虑一个名为 Product 的数据库表,其中包含以下记录:

ProductNamePriceStockQuantityOrderQuantity
Apple1.0010020
Banana1.2512030
Orange2.15105NULL
Watermelon3.507515

如果OrderQuantity是可选的并且可以包含NULL值。下面提到的语句将给出 NULL 值。

SELECT *, Price * (StockQuantity + OrderQuantity) AS Inventory  
FROM Product; 

这将产生如下所示的结果:

ProductNamePriceStockQuantityOrderQuantityInventory
Apple1.0010020120.0
Banana1.2512030187.5
Orange2.15105NULLNULL
Watermelon3.507515315.0

为了避免这种情况,COALESCE() 函数可用于为该列提供替代值。

SELECT *, Price * (StockQuantity + COALESCE(OrderQuantity, 0)) AS Inventory
FROM Product; 

这将产生如下所示的结果:

ProductNamePriceStockQuantityOrderQuantityInventory
Apple1.0010020120.0
Banana1.2512030187.5
Orange2.15105NULL225.75
Watermelon3.507515315.0